草庐IT

ios - RubyMotion 和指针

全部标签

c++ - shared_ptr 与指针共存

我有一个函数如下voida(shared_ptrval){...}有时候,我想传入一个堆分配的对象shared_ptrv(newX());a(v);其他时候,我想传入一个堆栈分配的对象classC{//doesn'tworkproperlyb/cwhentheshared_ptrdiesitwilltrytodeletex...C(){a(shared_ptr(&x));}Xx;};让函数接受智能指针,同时让智能指针引用堆栈分配对象的最佳方法是什么?或者我应该走Java路线并从堆中分配所有内容? 最佳答案 我只想让函数采用这样的模板

c++ - 指针数组

如何获得指向对象(类)的指针数组?我需要为它们动态分配空间,数组的长度直到运行时才确定。任何人都可以解释并告诉我如何定义它吗?并可能向他们解释它是如何工作的,这真的很好:) 最佳答案 改用std::vector。它旨在根据需要动态调整集合的大小。#include//...std::vectorvec;vec.push_back(my_class_ptr);Class*ptr=vec[0]; 关于c++-指针数组,我们在StackOverflow上找到一个类似的问题:

C++老师告诉我不要用指针

昨天我的老师告诉我不要使用指针,除非我想编写一些非常低级的东西。他说垃圾收集器会为我做所有事情,所以指针基本上是低效和危险的。我很生气,因为我以前听过不同之处。那么什么是对的,什么是错的呢?我应该使用指针吗?如果没有,为什么在没有人使用的情况下还要实现它们? 最佳答案 在C++中使用垃圾收集器需要严格的纪律,而且还需要相当称职的程序员,即使在C++11中增加了对垃圾收集的支持也是如此。所以你的老师可能是别的意思。可能他/她的意思是您应该优先使用标准库容器(如vector和string)和智能指针来处理您必须处理的所有权处理指针。这是

c++ - 如何优化指针间接层

我正在尝试在繁重的计算应用程序中优化这类事情:说我有一个doubled[500][500][500][500];至少从编译器的角度来看,以下是相当昂贵的doubled[x][y][j][k]我想告诉编译器它是连续的内存,以方便计算偏移量。在我的例子中,我有这样的东西:doublen=0;for(inti=0;i所以我试图通过将它放在一个单独的函数中来优化它voidfunc(double***constrestrictdMatrix){/*anddosomecalculationsherel*/}没有太大帮助:(有什么优化建议吗?编辑我无法重写代码使数组成为一维。我必须和这个多维的野兽一

c++ - 我可以通过 for_each <algorithm> 在 C++ 中的指针 vector 上调用 `delete` 吗?

假设我有一个std::vectorobjs(出于性能原因,我的指针不是实际的Objs)。我用obj.push_back(newObj(...));填充它反复。完成后,我必须delete被推回的元素。一种方法是这样做:for(std::vector::iteratorit=objs.begin();it!=objs.end();++it){delete*it;}但是,如果我可以使用for_each我很感兴趣算法做同样的事情:#include...for_each(objs.begin(),objs.end(),delete);你怎么看? 最佳答案

c++ - 在 C++ 中,如何获取指向 vector 的指针?

我正在编写一些C++代码来操纵一堆大小不断变化的vector,因此不断地重新分配。我想得到一个指向这些vector的“指针”,即使在重新分配vector后它仍然有效。更具体地说,我只想让这些“指针”记住它们指向哪个vector以及它们指向的索引。当我使用标准(*ptr)语法取消引用它们时,我只想让它们进行明显的查找。显然,实际指针在重新分配后将无效,我的理解是迭代器在重新分配后也无效。还要注意,我不关心元素是否插入到我的对象之前,所以这些“指针”实际上不需要记住任何东西,只需要记住一个vector和一个索引。现在,我可以轻松地自己编写这样的类。有没有人(Boost?STL?)已经为我完

c++ - 将智能指针所有权转移到容器

我的数据结构通常通过std::unique_ptr管理,例如AST中的表达式。structBinExpr{std::unique_ptrleft;//Leftownstheexpressionstd::unique_ptrright;//Rightownstheexpression};在大多数情况下效果很好。但有时我没有固定数量的表达式可以拥有,例如在列表中structListExpr{std::vector>exprs;//Exprsownspointerswhicheachownanexpression};但我不喜欢通过vector中的智能指针这种额外的间接寻址,我认为它没有表达我

【Git】05 分离头指针

文章目录一、分离头指针二、创建分支三、比较commit内容四、总结一、分离头指针正常情况下,在通过gitcheckout命令切换分支时,在命令后面跟着的是分支名(例如master、temp等)或分支名对应commit的哈希值。非正常情况下,gitcheckout切换分支时后面跟了一个非分支对应commit的哈希值,此时就会产生分离头指针问题。例如,项目的版本历史中有如下3次commit,其中两个分别是temp分支和master分支;此时将分支切换到第三个commit(也就是非temp、master分支)上,就会出现detachedHEAD提示,即分离头指针问题。gitlogcommite5d6

c++ - 使用 SDL_SetVideoMode 时,有没有办法获取内部 SDL_Window 指针或 ID?

如果您使用SDL_SetVideoMode()创建窗口,您将返回一个表面,而不是窗口句柄。有没有办法获得SDL_Window句柄?我知道有一个SDL_GetWindowFromID函数,但我也不确定如何获取ID,除了SDL_GetWindowID函数,这需要我已经拥有窗口句柄。有什么建议吗?请注意,保持跨平台可移植性非常重要,因此我更愿意尽可能坚持使用内置SDL功能。如果有帮助,我正在尝试获取和设置窗口位置和窗口大小,而这些函数需要窗口句柄。谢谢!编辑:我还应该提到我正在根据用户的请求更改视频模式,所以我不能只使用默认ID1,因为每次我调用SDL_SetVideoMode()时此ID都

c++ - 在 boost::ptr_unordered_map 中存储指向 const 对象的指针

我似乎做不到boost::ptr_unordered_map工作-底层实现看起来像是将东西转换为void*.我是否只需要硬着头皮让我的方法包装对此的访问做一个const_cast插入项目时,或者我在这里遗漏了什么?有什么方法可以存储指向const对象的指针(constFoo*)? 最佳答案 看起来这是不可能的。解决方法是包装对ptr_unordered_map的访问.插入方法应该采用constauto_ptr然后执行const_cast插入它。如果您在删除元素时将auto_type交还给客户端代码,则需要从中解压指针并将其传输到co